🧑💻
코드 처리하기
February 06, 2024
문제
문자열 code가 주어집니다.
code를 앞에서부터 읽으면서 만약 문자가 “1”이면 mode를 바꿉니다. mode에 따라 code를 읽어가면서 문자열 ret을 만들어냅니다.
mode는 0과 1이 있으며, idx를 0 부터 code의 길이 - 1 까지 1씩 키워나가면서 code[idx]의 값에 따라 다음과 같이 행동합니다.
mode가 0일 때code[idx]가 “1”이 아니면idx가 짝수일 때만ret의 맨 뒤에code[idx]를 추가합니다.code[idx]가 “1”이면mode를 0에서 1로 바꿉니다.
- mode가 1일 때 -
code[idx]가 “1”이 아니면idx가 홀수일 때만ret의 맨 뒤에code[idx]를 추가합니다. -code[idx]가 “1”이면mode를 1에서 0으로 바꿉니다. 문자열code를 통해 만들어진 문자열ret를 return 하는 solution 함수를 완성해 주세요.
단, 시작할 때 mode는 0이며, return 하려는 ret가 만약 빈 문자열이라면 대신 “EMPTY”를 return 합니다.
제한사항
- 1 ≤
code의 길이 ≤ 100,000code는 알파벳 소문자 또는 “1”로 이루어진 문자열입니다.
입출력 예
| code | result |
|---|---|
| “abc1abc1abc” | “acbac” |
입출력 예 설명
입출력 예 #1
-
code의 각 인덱스i에 따라 다음과 같이mode와ret가 변합니다.i code[i] mode ret 0 “a” 0 “a” 1 “b” 0 “a” 2 “c” 0 “ac” 3 “1” 1 “ac” 4 “a” 1 “ac” 5 “b” 1 “acb” 6 “c” 1 “acb” 7 “1” 0 “acb” 8 “a” 0 “acba” 9 “b” 0 “acba” 10 “c” 0 “acbac”
따라서 “acbac”를 return 합니다.
코드
function solution(code) {
// (1)
var mode = 0;
var answer = '';
// (2)
for (idx = 0; idx < code.length; idx++) {
// (3)
if (code[idx] === '1') mode === 0 ? (mode = 1) : (mode = 0);
// (4)
if (mode === 0) code[idx] !== '1' && idx % 2 === 0 && (answer += code[idx]);
// (5)
else code[idx] !== '1' && idx % 2 !== 0 && (answer += code[idx]);
}
// (6)
return answer === '' ? 'EMPTY' : answer;
}코드 해설
(1) mode 변수를 0으로 초기화하고 answer 변수를 빈 문자열로 초기화한다.
(2) 입력된 코드의 각 문자에 대해 반복한다.
(3)
- 현재 문자가 ‘1’인지 확인하고, 해당이 되면, 삼항연산자를 이용한다.
- mode값이 0이면 mode 값을 0과 1 사이에서 토글한다.
(4)
- mode를 확인하고 문자를 answer에 추가한다.
- 만약 mode가 0이면, 문자가 ‘1’이 아니고 짝수 인덱스일 때 answer에 추가한다.
(5) 만약 mode가 1이면, 문자가 ‘1’이 아니고 홀수 인덱스일 때 answer에 추가한다.
(6)
- answer가 여전히 빈 문자열인지 확인하고, 빈 문자열이면 ‘EMPTY’를 반환하고
- 그러지 않으면 answer값을 반환한다.